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Description 

FIELD OF THE INVENTION 

[0001] This invention relates, in general, to translation methods and apparatus using table lookup and specifically 
to collision resolution in hash-based lookup tables. 

BACKGROUND OF THE INVENTION 

[0002] Translation between data formats is a common problem in data processing systems. Often the operation of 
the data processing system is heavily dependent on the speed and efficiency of the translation process. For example 
one common example is the translation of stored binary data into a form suitable for transmission over a data network' 
[0003] A data network typically consists of several nodes, at which switches are located, connected together by data 
transport media. A common method of transmitting data over such a network is to exchange messages between the 
switches, which messages comprise discrete "packets" of data. These packets can be transported over the media with 
one of a variety of transport techniques. In applications utilizing packetized data, data to be transported is first broken 
up into discrete pieces or packets which are then transmitted through the switches and reassembled at a destination 
In accordance with current packet protocol, each packet generally consists of a header and an information field. The 
header contains the information used to transport the cell from one node to the next. The packet data is contained in 
the information field. 

[0004] In such networks, the data source and destination are often identified by unique numerical addresses and in 
accordance with many popular protocols, to insure that the network can be reasonably large, the address information 
in the headerfield of such system is also often large - on the order of 5-6 bytes or 40-48 bits. A 48-bit address field 
can identify 2*° or about 300 trillion unique addresses. However, most networks have on the order of a few thousand 
different terminals so that only a small fraction of the potential address pool is actually needed. 
[0005] The disparity in the potential number of addresses and the number of actual addresses causes inefficient use 
of resources. For example, if provisions were made to store each unique address, a large memory would be necessary 
but only a few memory locations would be used to store the actual addresses. Therefore, for efficient use of resources 
at each local node, smaller address fields, conventionally called forwarding addresses, are used and a translation is 
made between the larger address field used in the packet headers and the smaller address field used within each local 
node. 

[0006] A conventional translation method for translating addresses in packet switching systems uses a database in 
which the local, smaller addresses are stored. The larger addresses in the data packet headers are used to search 
the local database and retrieve the forwarding addresses. There are several well-known techniques for performing this 
search. One method is to use a binary tree search. Another method is to use a content addressable memory. Still other 
methods reiy on hashing techniques to generate an index into the database. These address translation methods are 
described in U.S. Patent Nos. 4,587.610; 4,993,937; 5,027,350 and 5,136,580. 

[0007] An important design objective in packet switching networks is controlling the flow of packets so that packets 
will not arrive at communication links or switches at a faster rate than they can be processed and forwarded to the next 
destination. If the packets cannot be processed rapidly, packet buffers may become full and packet loss will occur 
severely reducing the efficiency of the network. As a result, binary tree searches present difficulties In such networks 
For example, a forwarding address database which holds about sixteen thousand forwarding addresses (a 1 6K mem- 
ory) requires a 14-bit address. In the worst case, with a binary searching technique, such a memory could require 14 
reads in order to locate a particular address in the memory. This number of reads is prohibitive from a performance 
standpoint using commonly available semiconductor memories. 

[0008] Content addressable memories require only one read to compare a packet address with all stored addresses 
However, content addressable memories are complex and expensive and, thus, suitable only for systems in which the 
forwarding database is small. 

[0009] Another alternative is to use a hashing technique to convert the large number of packet header addresses 
into a smaller number of local forwarding addresses. Conventional hashing techniques use a mathematical transfor- 
mation to map each of the packet addresses into one of a set of index addresses which are used to index into the 
forwarding address database. Since a large number of addresses are being reduced into a much smaller number of 
addresses, some of the packet addresses will inevitably map into the same index address causing a "hash collision ■ 
Some technique must be used to resolve these hash collisions so that a unique index address can be generated from 
each packet address. 

[0010] On problem with these hashing techniques is that th fficiency of th m thod has been heavily dependent 
on the hashing transformation used in the procedur . Many hashing transformation suffer from poor memory usage 
low speed and large worst-case delays, thereby making them unsuitable for use in th packet switching address trans- 
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lation systems. In addition, many hashing techniques utilize special circuitry to resolve collisions and are thus expensiv 
and complicated. 

[001 1 ] Still other prior art techniques use a combination of the above-described techniques to perform the required 
translation. For example, U.S. Patent No. 5,41 4,704, the disclosure of which is hereby incorporated by reference, uses 

5 a programmable hashing technique to generat the forwarding address table indices and a binary search technique 
to handle hash collisions. In accordanc with th disclosed method, th data packet addresses are transformed by a 
hash transformation into indices for a hash table. The hash table includes as each table entry, a pointer to a set of 
forwarding table indices arranged in a small binary tree. Hash collisions, which cause two or more data packet ad- 
dresses to transform to the same hash table entry, are handled by performing a binary tree lookup to obtain a unique 

io forwarding address table index. Since the binary tree is small (typically three levels or seven total entries) the number 
of reads required to traverse the tree is also small thereby significantly reducing the lookup time. A content-addressable 
memory (CAM) is provided to handle the cases in which more than seven data packet addresses hash to the same 
hash table entry. 

[0012] While aforementioned combination arrangement offers a compromise in performance and cost, there are 
w many address combinations in which the CAM must be relatively large because a significant number of data packets 
addresses transform to the same hash table entry. The cost of the system is therefore increased. 
[001 3] Accordingly, there is a need for a translation method and apparatus which efficiently uses system resources, 
performs well and has a lower cost than presently-available translation or lookup systems. 

20 SUMMARY OF THE INVENTION 

[001 4] In accordance with the principles of the invention, a translation is performed by using a programmable hashing 
technique on an input number to generate a hashed number. A subset of the hashed number bits are used to index a 
first hash table. In first hash table locations where a hash collision does not occur, the first hash table entry contains 

25 an index into an output table which contains the desired translated output number. 

[0015] In first hash table locations where a hash collision occurs, the first hash table entry contains a pointer to a 
first resolution table area in a second hash table. The first resolution table area contains entries which are indexed by 
additional bits selected from the hashed number in accordance with a mask field in the first hash table location. In the 
first resolution area, in each entry where a collision does not occur, the first resolution table entry contains an index 

30 into the output table which contains the desired translated output number. In each first resolution table entry where a 
collision does occur, the entry contains a pointer to a second resolution area in a third hash table. The second resolution 
table area contains entries which are indexed by still more bits selected from the hashed number in accordance with 
a mask field in the first resolution table location. The entries in the second resolution table may be indices into the 
output table or additional pointers to still further resolution tables, if hash collisions occur in the second resolution table. 

35 in this manner, new levels of resolution tables can be added using additional bits selected from the hashed number 
until ail entries are resolved. There is no need to resort to additional circuitry or techniques to resolve hash collisions. 
[0016] In accordance with one embodiment of the invention, each hashed number is stored in a hash remainder 
m table at an address indexed by the same index which is generated to index the output table. When the index has been 
generated, it is used to retrieve the stored hash number which is compared to the original hash number. A match 

to indicates that the retrieval mechanism has retrieved a valid index and the forwarding information is retrieved from the 
output table and returned. If no match is obtained, default forwarding information is returned. 

BRIEF DESCRIPTION OF THE DRAWINGS 

45 [0017] The above and further advantages of the invention may be better understood by referring to the following 
description in conjunction with the accompanying drawings and which: 

[001 8] Figure 1 is a block schematic diagram of a data packet switching network on which the inventive method and 
apparatus may run. 

[0019] Figure 2 is a more detailed block schematic diagram of a data packet switch which diagram illustrates the 
50 flow of data packets through the switch. 

[0020] Figures 3A and 3B are schematic diagrams illustrating the data format in the three lookup hash tables in the 
case of no collision and in the case of a collision, respectively. 

[0021] Figure 4 is a schematic diagram illustrating a translation process conducted in accordance with the principles 
of the present invention when no hash collision occurs. 
55 [0022] Figure 5 is a schematic diagram illustrating translation processing in accordance with the principles of the 
pres nt invention wh n a hash collision occurs. 
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with the data to determine whether and how the outgoing packet must be encapsulated. For example, the packet may 
need some header bytes appended. 

[0032] The inventive lookup process is performed by lookup engine 202 which is a process which runs in the proc- 
essor of the associated switch. The lookup argument provided to the lookup engine by th input port may be a 48-bit 
MAC address, or other information, such as a 5-byte Protocol Identifier (PID), a 2-byte Protocol Type (PT) or a one- 
byte Destination Service Access Point (DSAP). Th lookup engine 202 pads each lookup argument with a type code 
and, if necessary, zero-value bytes to make all lookup arguments 48-bits wide. The 48-bit width is merely illustrative 
and any other lookup argument width can also be used in accordance with the principles of the invention. 
[0033] More particularly, the lookup engine classifies each input value into one of four types. Padding is applied as 
necessary to make the argument 48 bits wide, and a 4-bit Type code is tagged to the argument. The following Table 
1 illustrates type codes and padding values used for the various lookup argument types in accordance with one illus- 
trative embodiment: 



TABLE 1 



15 



20 



Lookup Type 


Type Code 


Padding Prefix 


MAC address 


1 


(none) 


PID 


8 


8D 


PT 


9 


9D 00 00 00 


DSAP 


A 


AD 00 00 00 00 



30 



35 



40 



45 



50 



[0034] The padding values are added to the left of the argument string so that the least significant bit of the padded 
result (bit 0) corresponds to bit 0 of the rightmost byte in the lookup argument and the most significant bit of the result 
(bit 47) corresponds to the most significant bit of the leftmost byte of the (padded) result. In accordance witfi a preferred 
embodiment, the specific padding prefixes are chosen to minimize the chance of collisions with assigned IEEE multicast 
addresses. In addition, as described below, the lookup type is stored for a later comparison with the information retrieved 
by the hash lookup process. Therefore, there is no possibility that addresses can be confused with protocols. The 
lookup argument is then hashed to provide a hashed argument, which is used to access tables 204 to perform the 
inventive lookup process. 

[0035] Tables 204 are sized and built at system initialization or later during operation whenever the network is recon- 
figured by adding stations or switches. They consist of three hash tables, and a hash remainder table. At system 
initialization time, the number and distribution of initial system addresses are known sot hat the hash and remainder 
tables can be constructed. Also at this time, a unique forwarding value is selected for each address in the address set 
which forwarding value will be used to route the packet through the switch, these forwarding values are stored in a 
forwarding table which is indexed by a forwarding index. Later when stations or ports are added or deleted, the corre- 
sponding addresses are added or deleted and tables 204 are recomputed. 

[0036] As previously mentioned, the goal is to provide a reduction in the number of potential addresses represented 
by a 48-bit data packet address field to a much smaller number of addresses, typically represented by a 12 to 16 bit 
address field. In accordance with a preferred embodiment, the reduced address size, and, accordingly, the size of the 
hash tables can be selected p rog ram matical ly. Theoretically, it would be possible to red uce the size of the 48-bit address 
by simply using a subset of the bits, for example, the least significant 12-16 bits. However, practically, the addresses 
often contain sequences in certain unpredictable bit positions that make address compression by simple bit field ex- 
traction unreliable. 

[0037] Therefore, the lookup tables are built with a programmable randomizing function, called a hash function, 
designed to generate a small number (less than 64K) of indices corresponding to a set of (up to 64K) lookup arguments. 
Ideally, the mapping from arguments to indices is one-to-one, but a small number of many-to-one mappings can be 
tolerated. The hash function converts the 48-bit input argument into a new 48-bit output argument, called the hashed 
argument, using a process based on polynomial multiplication and division. Specifically, the bits of the input argument 
(either 1 or 0) are considered to represent the coefficients of an order-47 polynomial in x; if this is called A(x), then: 



A(x) = a 47 .x 47 + a^ .x 48 + .... + a^ .x 2 + a 1 .x + a 0 
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where the coefficients - a 47 are the bit values of the 48-bit input argument. In accordance with the hash function, 
this input polynomial is multiplied by a programmable hash multiplier which is stored in memory. The hash multiplier 
M(x) is repr sented by the polynomial: 



h j r r J — ■ • »-w..»# "mi iy ihuuuiu t- duuiuwii, iura j ik>iuw mi wiuoi *7T r " t iwi nioi mill 

5 coefficients that are also 0 or 1 . This product is finally divided by a generator polynomial G(x), of fixed value given by: 

G(x) = x" + x* + x 25 + x 10 + 1 

10 [0039] The division is again carried out using modulo-2 addition. The division yields a quotient Q(x), which is a 
polynomial of order 46, and a remainder R(x) which is a polynomial of order 47. The operands are related by the 
quation: 

15 A(x)*M(x) = Q(x)+R(x)*G(x) 



[0040] The generator polynomial is chosen such that for any given multiplier polynomial (except 0), there is one-to- 
one mapping between the set of all values of A(x) and the corresponding set of all values R(x). The quotient Q(x) can 
therefore be discarded, as any value A(x) is derivable from its corresponding R(x). By choosing a suitable value for M 
20 (x), any given bounded set of lookup arguments (a subset of all values of A(x)) can be mapped onto a set of hashed 
arguments (a subset of all values of R(x)) with high likelihood of uniqueness in the low order 1 6 bits (maybe as few as 
1 2 bits) of R(x). Statistical trials have shown that a random value M(x) is often sufficient, with retries beyond two attempts 
being very unlikely. 

[0041] Since the multiplier polynomial M(x) can be programmatically selected, it can be changed and the hash table 

25 rebuilt during operation of the system if it is found that a large number of hash collisions is occurring with a particular 
set of addresses. This avoids problems which are often encountered with fixed hash functions and certain address 
sets. In order to improve performance, the multiplier polynomial should be selected to minimize the number of collisions 
and the hash table size should be selected so that it is in sparsely populated (for example, the hash table size may be 
on the order of four times larger than the number of address entries). 

30 [0042] A first hash table is then constructed by first selecting the number of bits in the reduced address field which 
determines the size of the first hash table and the width of the first hash table words (each word has a width equal to 
the number of bits in the hash index plus one for a collision flag.) The first hash table is next initialized with a zero in 
each entry. Each address is then hashed in accordance with the hash function described above to generate a hashed 
argument. The hashed argument is then used as an index into the first hash table. 

35 [0043] If the indexed location is empty, the zero entry is replaced by a data entry shown in Figure 3A. This entry has 
the most significant bit 300 assigned as a "collision flag" which is set to "0". The remaining bits are assigned to the 
unique forwarding index which is selected as previously described. In this case the complete hashed argument and 
„ the type code are also entered in the hash remainder table at a location indexed by the unique forwarding index. 
[0044] Alternatively, if a forwarding index is already present in the indexed location, the entry illustrated in Figure 3B 

40 is made at the indexed location. In this entry, the collision flag 304 is set to "1" and the stored forwarding value is 
replaced by a collision entry. The collision entry comprises a bit mask field 306 and a next table index 308. The collision 
entry will instruct the lookup engine 202 to use more bits from the hashed argument, in conjunction with resolution 
areas in the additional hash tables 2 or 3 to resolve the collision. 

[0045] The bit mask field is a 4-bit mask number which specifies one of sixteen functions which will be used to create 
45 a new 1 4-bit resolution table index from the 1 2-bit next table field and specified extra bits of the hashed argument when 
the lookup function is performed This new resolution table index will be used to access a resolution table in either the 
second or third hash table to resolve the collision. The definition of the sixteen possible functions is shown in Table 2 
below: 

so TABLE 2 



Mask No. 


Hash Table 


Bit Mask 


Shift Amount 


Resolution Table Index 


0000 


2 


00000011 


2 


NextTablelndexa-XX" 


0001 


2 


00000101 


3 


NextTablelndex&"XX" i 


0010 


2 


00000110 


3 


NextTablelndex&"XX" 


0011 


2 


00001001 


4 


NextTablelndex&"XX" 


0100 


2 


00001010 


4 


NextTablelndex&"XX" 
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TABLE 2 (continued) 



10 



15 



Mask No. 


Hash Tabl 


Bit Mask 


Shift Amount 


Resolution Table Index 


0101 


2 


00001100 


4 


NextTablelndex & "XX" 


0110 


2 


00010001 


5 


NextTablelndex & "XX" 


0111 


2 


00010010 


5 


NextTabl Index & "XX" 


1000 


2 


00010100 


5 


NextTablelndex & "XX" 


1001 


2 


00011000 


5 


NextTablelndex & "XX" 


1010 


3 


00001111 


4 


NextTablelndexJ11..2) & "XXXX" 


1011 


3 


00000110 


5 


NextTablelndex^(11..2) & "XXXX" 


1100 


3 


00111100 


6 


NextTablelndex (11 ..2) & "XXXX" 


1101 


3 


01111000 


7 


NextTablelndex (11. .2) & "XXXX" 


1110 


3 


11110000 


8 


NextTablelndex (11 ..2) & "XXXX" 


1111 


3 


11111111 


8 


NextTablelndex (1 1.. 6) & 


"XXXXXXXX" 











20 



25 



30 



35 



40 



45 



50 
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[0046] In this table, the values in the column titled "Hash Table" indicates whether the resolution table used to resolve 
the collision is part of the second hash table or part of the third hash table. The values in the column titled "Bit Mask" 
is an abstract mask that indicates which bits are to be selected from the low-order 8 bits of the shifted hashed argument. 
The "Shift Amount" column indicates how many bit positions to shift to the right the hashed argument after the bit mask, 
is applied and bits to be used in the present resolution stage are selected. The shifting operation causes new bits of 
the hashed argument to be used during each stage of the resolution process. Finally, the column entitled "Resolution 
Table Index" indicates how to form the index into the resolution table by concatenating (indicated by the "&" symbol) 
the Next Table Index bits from the collision entry with the bits selected from the shifted hash argument (indicated by 
"X"s.) 

[0047] In order to select the bit mask number, the set of addresses is examined to determine which of the bits in the 
upper 1 6 bits is most likely to change and a mask number is selected for which the corresponding bit mask selects 
those bits. This mask number is inserted in the mask number field of the collision entry. Then, a resolution table is 
created in the second or third hash tables in accordance with Table 2 above depending on the mask number selected. 
Resolution tables in the second hash table always have four entries and resolution tables in the third hash table always 
have either sixteen or 256 entries. The upper 12 bits of the resolution table base address are put into the Next Table 
Index Field of the collision entry. The mask is applied to the upper bits of the hashed address to determine the entry 
position in the newly created resolution table and entry as illustrated in Figure 3A is inserted into the table indicating 
the forwarding address. 

[0048] Operation continues in this fashion. If a collision is detected in the second resolution table, then the forwarding 
address entry illustrated in Figure 3A is replaced by a collision entry as shown in Figure 3B and a new resolution table 
is created. The operation continues in this manner until all addresses have been processed. 
[0049] Figure 4 illustrates the basic translation process which occurs when no collisions are detected. As previously 
mentioned there are four basic types of address information on which to perform a lookup operation. In the Figure, the 
address information is assumed to be 48 bits wide. This address information is loaded into register 400. A four bit type 
code is loaded into register 402 for a comparison as will be described in detail below. 

[0050] The address information in register 400 and a multiplier M(x), discussed above and stored in register 406, 
are provided to a hasher process which generates a hashed argument in accordance with the technique as described 
above. The hashed argument is stored in register 408. 

[0051] The lower 12 to 16 bits of the hashed argument in register 408 are used as a hash index to access the first 
hash table 420 as indicated by arrow 410. If the value zero (as initialized by the user and indicated, for example, by 
entry 422) is stored at the location identified by the hash index, then a forwarding index for the hashed argument is 
not stored in any of the hash tables. Conversely, if the first hash table entry is non-zero (for example, entries 424 and 
426), then it is possible (though not definite) that a forwarding index is stored in one of the hash tables. 
[0052] More specifically, if the hash index identifies a non-zero entry from the first hash table which indicates no 
collision (the collision flag is , 0\ as indicated by entry 426), then a possible forwarding index can be retrieved from the 
first hash table as illustrated by arrow 418. Since many addresses may alias to the same hash index, the forwarding 
index is used to access the hash remainder table, as indicated by arrow 434, and retrieve the type code 428 and 
hashed valu of the address 430 previously stor d at the location accessed by th r tri v d forwarding index. Th 
retriev d typ code is compared in comparator 412 to th type cod stored in register 402. The retrieved hashed 
argument is compared to the hashed argument stored in r gister 408 by comparator 41 6. th outputs of comparators 
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412 and 416 are provided to a decision process 414. If the hash remainder table entries 428 and 430 and the type 
code in register 402 and the hashed argument in register 408 are equal, the decision process 41 4 uses the retrieved 
forwarding index on line 434 to access a forwarding table 438 to retrieve a forwarding value, the forwarding value is 
used, as previously discussed, to route the data packet through the packet switch. Alternatively, if the comparators 
412 and 416 do not both indicate a match, an alias has been found and a default index is returned. 
[0053] If the hash index identifies a collision entry in the first hash table as illustrated by entry 424 in which the 
collision flag is " 1" , then further processing must be performed to resolve a collision caused when two or more different 
addresses generate the same hash index. 

[0054] Figure 5 illustrates collision processing performed in accordance with the principles of the present invention. 
As shown in Figure 5, resolution tables in the second and third hash tables are used to resolve collisions until forwarding 
indexes are retrieved for all addresses. The resolution process proceeds in stages. At each stage in the collision 
resolution process additional bits from the hashed argument are used in combination with an index stored in the collision 
entry to access a resolution table. This process is repeated until a resolution is obtained. 

[0055] More specifically, a hash index formed of the 12-1 6 least significant bits of the hashed argument 500 (stored 
in register 408 in Figure 4) is applied to the first hash table 504 as previously discussed. In the illustrative example 
shown in Figure 5, four addresses collide, or generate hashed arguments which index the same entry, in the first hash 
table 504. Accordingly, when the first hash table was generated as discussed above, a collision entry 506 has been 
made in the entry indexed by the hash index. 

[0056] The collision entry 506 in the first hash table 504 contains a next table index (NTI) which points to a first 
resolution table 510 located In the second hash table address space. A mask field (indicated by 'M') in the collision 
entry 506 describes how to create an offset into the first resolution table 510 by using two bits from the next 2, 3, 4 or 
5 higher order bits (31 ..16) of the hashed argument 500. As previously mentioned, the bit mask indicated which of the 
next 2-5 should be selected. The bits selected by the bit mask as indicated by arrow 509 are concatenated with the 
NTI as indicated by concatenator 508 to provide an index into the resolution table 510. After the index is generated 
the hashed argument in register 500 is shifted so that new bits of the hashed argument will be used in further stages 
of the resolution process. 

[0057] As previously mentioned, all second hash table resolution tables have four entries, whose formats are identical 
to the first hash table entry formats illustrated in Figures 3A and 3B. Using the two bits selected by the bit mask M in 
the collision entry 506, in the illustrative example, three addresses still collide in the first resolution table 510. In par- 
ticular, the three addresses index to entry 514. One address indexes to entry 512 and is accordingly, collision free. 
Therefore entry 512 contains a forwarding index, the translation process will check for a match in the hash remainder 
table using this forwarding index (if the address is accessed) as discussed above with respect to Figure 4. 
[0058] The three colliding addresses require another resolution table 51 8 to be created. In the illustrative example, 
another resolution table located in the second hash table address space is used. Because there is a collision in the 
first resolution table, the table entry will have a collision entry 514 of the format illustrated in Figure 3B entered at the 
time the table is created. The bit mask in entry 51 4 specifies a further two bits from the next higher order 2 to 5 bits in 
the hashed argument that are to be used to index this second resolution table. 

[0059] The selected bits as indicated by arrow 515, are concatenated by concatenator 51 6 with the next table index 
in entry 51 4 to access the second resolution table 518. 

[0060] In this case, there are still two colliding addresses In the second resolution table 518 and one entry 520 is 
collision free. The collision free entry 520 is processes as described above in connection with the first resolution table. 
The entry 522 to which the two remaining addresses index is arranged to point to a third resolution table 526. This 
third resolution table 526 is located in the third hash table address space and contains either sixteen entries or 256 
entries, which are indexed by 4 or 8 bits selected from a field of 4 to 8 higher order bits in the hashed argument. As 
with the previous resolution stages, the bit mask M in the collision entry 522 specifies which bits on the next least 
significant bits of the hashed argument are to be used to access the third resolution table 526. The selected bits as 
indicated by arrow 525 are concatenated by concatenator 524 and used to index the third resolution table 526. 
[0061] In the illustrative example, the remaining two addresses are resolved in the third resolution table 526 as 
indicated by entries 530 and 532. Accordingly, each of these entries contains a forwarding index which is processed 
as previously described. 

[0062] The amount of resolution processing which must be performed in accordance with the principles of the inven- 
tion depends on the initial address set, the hashing method used and the size of the first hash table. Consequently, 
the values for the hash multiplier and the first hash table size should be selected so that collisions in the first hash 
table are minimized. It is also preferred to make the size of the hash table significantly larger (for example, four times 
larger) than the number of expected entries in order to spread the entries over the address space and minimize the 
possibility of collisions. 

[0063] While the invention has been shown and described abov with respect to various preferred embodiments, it 
will apparent that the foregoing and other changes of the form and detail may be made th rein by one skilled in th art 
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without departing from the scope of the invention. Thes and other obvious modifications are intended to be covered 
by the following claims. 



5 Claims 

1. An apparatus for resolving a hash collision that occurs in a hash table (420) having a plurality of locations, the 
hash collision occurring when a first input number generates a first hashed value (408,500) and a second input 
number generates a second hashed value (408,500), wherein a first portion (410,502) of the first hashed value 

10 (408,500) and a first portion (41 0,502) of the second hashed value (408,500) have a same value, the first portion 

(410,502) of the first hashed value (408,500) being used to access a first location in the hash table, the apparatus 
characterized by: 

a first resolution table (510) containing a plurality of locations; 
15 a circuit to insert a collision entry (424,506) into the first location in the hash table (420,504) and into each 

hash table location where a hash collision occurs, the collision entry containing a bit mask number (M) iden- 
tifying a masking function to select a second portion (509) of the first hashed value (408,500) and a pointer 
(NTI) to the first resolution table (508); and 

an index generator (508) to generate a first index, responsive to the collision entry (424,506) and to the second 
20 portion (509) of the first hashed value (408,500) selected by the masking function, to access a resolution entry 

(512,514) at a location in the first resolution table (510), the location being pointed to by the generated first 
index. 

2. The apparatus according to claim 1 , wherein the index generator (508) combines the pointer (NTI) contained in 
25 the collision entry (424,506) with the second portion (509) of the first hashed value (408,500). to access the res- 
olution entry (512,514). 

3. The apparatus according to claim 1 , wherein the first portion (41 0,502) of the first hashed value (408,500) is used 
to access the first location in the hash table (420,504), and wherein the second portion (509) of the first hashed 

30 value (408,500) used by the index generator (508) is different from the first portion (410,502) of the first hashed 

value (408,500). 

4. The apparatus of claim 1 , wherein each of the plurality of locations of the hash table (420,504) containing a non- 
zero entry contains a flag set to one of a first logic value when the entry is a collision entry (424,506) and a second 

35 logic value when the entry is a non-collision entry (426). 

5. The apparatus of claim 1 , wherein the resolution entry is a non-collision entry (426) including a forwarding index 
(INDEX) to an output table (438) which contains a first output number (436). 

^0 6. The apparatus of claim 1 , wherein the resolution entry (514) is a collision entry including a bit mask (M) number 
identifying a masking function and a pointer (NTI) to a second resolution table (518) with a plurality of locations. 

7. The apparatus of claim 1 , further comprising a hasher (404) to receive a plurality of input numbers, and operative 
to generate a hashed value (408,500) for each input number of the plurality of input numbers, each hashed value 

45 (408,500) used to access a location in the hash table (420,504). 

8. The apparatus of claim 1 , wherein each of the plurality of locations of the hash table (420,504) that contain a non- 
zero non-collision entry include a forwarding Index to an output table (438) that contains a first output number (436). 

50 9. The apparatus of claim 8, wherein the apparatus classifies the first input number as one of four types, the apparatus 
further comprising a hash remainder table (432) including a plurality of entries, a first entry containing a hashed 
value (430) and a type (428) of the first input number, the apparatus operative to verify a forwarding index (FOR 
IDX) of a hash table entry accessed by the first hashed value (408,500) using the first entry of the hash remainder 
table (432), which is pointed to (434) by the forwarding index (FOR IDX). 



55 



10. The apparatus of claim 1 , wherein th masking function specifies bits to b selected from th first hashed valu 
(408,500). 



12. The apparatus of claim 1 , wherein th masking function specifies how to combine tne collision eniry ^4,ouo; 
5 with the second portion (509) of the first hashed value (408,500) to generate the first index. 

13. A method of resolving a hash collision that occurs in a hash table (420) having a plurality of locations, the hash 
collision occurring when a first input number generates a first hashed value (408,500) and a second input number 
generates a second hashed value (408,500), wherein a first portion (410,503) of the first hashed value (408,500) 

10 and a first portion (41 0,502) of the second hashed value (408,500) have a same value, the first portion (41 0,502) 
of the first hashedvalue (408,500) being used to access a first location inth hashtabl , the method characterized 
by: 

creating a resolution table (510) containing a plurality of entries; 

inserting a collision entry into the first location in the hash table (504) and into each hash table location where 
a hash collision occurs, the collision entry (424,506) containing a bit mask number (M) identifying a masking 
function to select a second portion (509) of the first hashed value (408,500) and a pointer (NTI) to the resolution 
table (510); 

generating an index responsive to the collision entry (506) and the second portion (509) of the first hashed 
value (408,500) selected by the masking function; and 

accessing a resolution entry (512,514) at a location in the resolution table (510) pointed to by the generated 
index. 

14. The method according to claim 13, wherein generating an index comprises: 

25 

combining the collision entry pointer (NTI) with the second portion (509) of the first hashed value (408,500). 

1 5. The method according to claim 1 3, further comprising: 

30 using the first portion (41 0,502) of the first hashed value (408,500) to access the first location in the hash table 

(420,504), the first portion (41 0,503) of the first hashed value (408,500) being different from the second portion 
(509) of the first hashed value (408,500). 

16. The method of claim 13, further comprising inserting into each of the plurality of locations of the hash table (420,504) 
35 containing a non-zero entry a flag set to one of a first logic value when the entry is a collision entry (424,506) and 

a second logic value when the entry is a non-collision entry (426). 

17. The method of claim 13, wherein the resolution entry is a non-collision entry (512), the method further comprising 
inserting Into the resolution entry a forwarding index (INDEX) to an output table (438) that contains an output 

40 number (436). 

18. The method of claim 13, wherein the resolution entry is a collision entry (514), the method further comprising 
inserting Into the resolution entry a bit mask number (M) identifying a masking function and a pointer (NTI) to 
another resolution table (518) having a plurality of locations. 

45 

19. The method of claim 13, further comprising: 

hashing a plurality of input numbers to generate a hashed value (408,500) for each of the input numbers; and 
applying each hashed value (408,500) to access a location in the hash table (420,504). 

so 

20. The method of claim 1 3, further comprising inserting a forwarding entry index (FOR IDX) to an output table (438) 
that contains a first output number (436) into each of the plurality of locations of the hash table (420,504) that 
contain a non-zero collision entry. 

55 21 . The method of claim 20, further comprising: 

classifying the first input number as on of four types; 

generating a hash remainder tabl (432) having a plurality of entries, a first entry containing a hashed value 

. . ^'*.&Vi IN- • «, - .v.- i l i -■ 
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(430) and a typ (428) of th first input number, and 

verifying a forwarding index (FOR IDX) of a hash tabl entry accessed by th first hashed value (408,500) 
using the first ntry of the hash remainder table (432), which is pointed to by the forwarding index (FOR IDX). 

22. The method of claim 13, wherein the masking function specifies a number of bit positions to shift the first hashed 
value (408,500) after th second portion (509) of the first hashed value (408,500) has been selected. 

23. The method of claim 13, wherein the masking function specifies how to combine the collision entry (424,506) with 
the second portion (509) of the first hashed value (424,506) to generate the index. . 

24. The method of claim 13, wherein the masking function specifies bits to be selected from the first hashed value 
(408,500). 

25. A translation apparatus for translating a plurality of input numbers into a plurality of output numbers, the apparatus 
comprising: 

a hasher (404), responsive to each of the plurality of input numbers, to generate a hashed argument (408,500) 
corresponding to the each input number, the hashed argument (408,500) having a plurality of bits; 
a hash table (420,504) containing a plurality of entries, each entry of the plurality of entries containing either 
an index (FOR IDX) to an output table (438) which contains a first output number (436) or a bit mask number 
(M) identifying a masking function and a pointer (NTI) to a resolution table (518); 

a first resolution table (510) containing a plurality of entries, each entry of the plurality of entries containing 
either an index (INDEX) into the output table (438) which contains a second output number or a bit mask 
number (M) identifying a masking function and a pointer (NTI) to a second resolution table (51 8); 
a first index generator responsive to a first subset (410,502) of the plurality of bits of the hashed argument 
(408,500) to access the hash table (420,504); and 

a second index generator (508) to access the first resolution table (510), responsive to an entry (506) in the 
hash table (420,504) that contains a bit mask number (M) and a pointer (NTI), and responsive to a second 
subset (509) of the plurality of bits of the hashed argument (408,500), wherein no bit from the hashed argument 
(408,500) is included in both the first subset (410,502) and second subset (509). 

26. The apparatus of claim 25, wherein the apparatus classifies each of the plurality of input numbers as one of four 
types, the apparatus further comprising a hash remainder table (432) having a plurality of entries, each entry 
containing a hashed value (430) and a type (428) of the input number, the apparatus operative to verity an index 
of an entry of either the hash table (420,504) or the first resolution table (51 0) using an entry of the hash remainder 
table (432) pointed to by the index. 

27. The apparatus of claim 25, wherein each location of the plurality of locations in each of the hash table (420,504) 
and the first resolution table (510) includes a collision flag, wherein for each entry of the plurality of entries where 
a hash collision does not occur the flag has a first logic value, and for each entry of the plurality of entries where 
a hash collision occurs the flag has a second logic value. 



PatentansprQche 

1 . Vorrichtung zum Auflosen einer Hash-Kollision, die in einer Hash-Tabelle (420) mit einer Vielzahl von Speicher- 
zellen vorkommt, die Hash-Kollision kommt vor wenn eine erste Eingabezahl einen ersten Hash-Wert (408, 500) 
erzeugt und eine zweite Eingabezahl einen zwelten Hash-Wert (408, 500) erzeugt, bei der ein ersterTeil (410, 
502) des ersten Hash-Wertes (408, 500) und ein ersterTeil (410, 502) des zweiten Hash-Wertes (408, 500) einen 
gleichen Wert aufwelsen, der erste Teil (41 0, 502) des ersten Hash-Wertes (408, 500) dazu genutzt wird, auf eine 
erste Speicherstelle In der Hash-Tabelle zuzugreifen, wobei die Vorrichtung gekennzelchnet ist durch: 

eine erste Auflosungstabelle (510), die eine Vielzahl von Speicherstellen enthalt; 

eine Schaltung, urn einen Eintrag einer Kollision (424, 506) in die erste Speicherstelle in der Hash-Tabelle 
(420, 504) und in jede Hash-Tab llen-Speicherst II , bei der ein Hash-Kollision vorkommt, inzufugen, wobei 
der Eintrag Iner Kollision ein Bitausblendzahl (M) enthalt, di ein Ausblendfunktion identifiziert, urn einen 
zweiten T il (509) d s rsten Hash-Wertes (408, 500) und einen Zeiger (NTI) auf di rst Auflosungstab II 
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(508) auszuwahlen; 

einen Indexgenerator (508), urn einen ersten Index, der auf den Eintrag einer Kollision (424, 506) und auf den 
zweiten Teil (509) des ersten Hash-Wertes (408, 500), der durch die Ausblendfunktion ausgewahlt 1st, an- 
sprechempfindlich 1st, zu erzeugen, urn auf einen Eintrag einer Auflosung (512, 51 4) bei einer Speicherstelie 
in der ersten Aufldsungstabelle (510) zuzugreifen, wobei auf die Speicherstelie durch den ersten erzeugten 
Index gezeigtwird. 

2. Vorrichtung gemsiB Anspruch 1 , 

bei der der Indexgenerator (508) den Zeiger (NTI), der In dem Eintrag einer Kollision {424, 506) mit dem zweiten 
Teil (509) des ersten Hash-Wertes (408, 500) enthalten, ist, verbindet, um auf den Eintrag einer Auflosung (512, 
514) zuzugreifen. 

3. Vorrichtung gemaB Anspruch 1 , 

bei der der erste Teil (41 0, 502) des ersten Hash-Wertes (408, 500) verwendet wird, um auf den ersten Speicher- 
platz In der Hash-Tabelle (420, 504) zuzugreifen, und bei der der zweite Teil (509) des ersten Hash-Wertes (408, 
500), der von dem Indexgenerator (508) genutzt wird, von dem ersten Teil (410, 502) des ersten Hash-Wertes 
(408, 500) verschieden ist. 

4. Vorrichtung gem§B Anspruch 1 , 

bei der jede der Vielzahl von Speicherstellen der Hash-Tabelle (420, 504), die einen von null unterschiedlichen 
Eintrag enthalt, einen Rag-Satz entweder eines ersten logischen Wertes, wenn der Eintrag ein Eintrag einer Kol- 
lision (424, 506) ist, oder elnes zweiten logischen Wertes, wenn der Eintrag ein Eintrag einer Nicht-Kollision (426) 
Ist, enthalt. ' 

5. Vorrichtung nach Anspruch 1 , 

bei der der Eintrag einer Auflosung ein Eintrag einer Nicht-Kollision (426) ist, die einen Weiterleitungsindex (INDEX) 
auf eine Ausgabetabelle (438), die eine erste Ausgabezahl (436) enthalt, einschlieBt. 

6. Vorrichtung nach Anspruch 1 , 

bei der der Eintrag einer Auflosung (514) ein Eintrag einer Kollision ist, die eine Bitausblendzahl (M), die eine 
Ausblendfunktion und einen Zeiger (NTI) auf eine zweite Aufldsungstabelle (518) mit einer Vielzahl von Speicher- 
stellen erkennt, einschlieBt. 

7. Vorrichtung nach Anspruch 1 , 

die femer einen Hasher (404) zum Empfangen einer Vielzahl von Eingabezahlen und Im Betrieb zum Erzeugen 
eines Hash-Wertes (408, 500) fur jede Eingabezahl der Vielzahl von Eingabezahlen umfasst, wobei jeder Hash- 
Wert (408, 500) verwendet wird, um auf eine Speicherstelie in der Hash-Tabelle (420, 504) zuzugreifen. 

8. Vorrichtung gemaB Anspruch 1 , 

be! der jede der Vielzahl von Speicherstellen der Hash-Tabelle (420, 504), die einen von null verschledenen Eintrag 
einer Nicht-Kollision enthalten, einen Weiterleitungsindex auf eine Ausgabetabelle (438), die eine erste Ausgabe- 
zahl (436) enthalt, einschlieBt. 

9. Vorrichtung gemSB Anspruch 8, 

bei dem die Vorrichtung die erste Eingabezahl als eine von vier Typen klassifiziert, 

die Vorrichtung ferner eine Hash-Ruckstandstabelle (432) enthalt, die eine Vielzahl von Eintragen umfaBt, wobei 
ein erster Eintrag einen Hash-Wert (430) und einen Typ (428) der ersten Eingabezahl enthalt, 
die Vorrichtung im Betrieb einen Weiterleitungsindex (FOR IDX) des Eintrags der Hash-Tabelle, auf den durch den 
ersten Hash-Wert (408, 500) durch Benutzung des ersten Eintrags der Hash-Ruckstandstabelle (432), auf die 
durch den Weiterleitungsindex (FOR IDX) gezeigt wird (434), zugegriffen wird, verifiziert. 

10. Vorrichtung gemaB Anspruch 1 , 

bei der die Ausblendfunktion Bits spezifiziert, die von dem ersten Hash-Wert (408, 500) ausgewahlt werden sollen. 

1 1 . Vorrichtung gemaB Anspruch 1 , 

b i der die Ausblendfunktion eine Anzahl von Bitpositlonen spezifiziert, um den ersten Hash-W rt (408, 500), 
nachd m der zweite Teil (509) des ersten Hash-Wertes (408, 500) ausgewahlt worden ist, zu verschieben. 
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12. Vorrichtung gemaB Anspruch 1 , 

bei der di Ausblendfunktion spezifiziert, wie der Eintrag einer Kollision (424, 506) mit dem zweit n Teil (509) des 
ersten Hash-Wertes (408, 500) zu verbinden ist, urn den ersten Index zu erzeugen. 

5 13. Verf ahren zum Auf Idsen einer Hash-Kollision , die in einer Hash-Tabelle (420) mit einer Vielzahl von Speicherzellen 
vorkommt, die Hash-Kollision kommt vor wenn eine erste Eingabezahl einen rsten Hash-Wert (408, 500) erzeugt 
und eine zweite Eingabezahl einen zweiten Hash-Wert (408, 500) erzeugt, worin ein ersterTeil (410, 502) des 
ersten Hash-Wertes (408, 500) und ein ersterTeil (410, 502) des zweiten Hash-Wertes (408, 500) einen gleichen 
Wert aufweisen, der erste Teil (410, 502) des ersten Hash-Wertes (408, 500) dazu genutzt wird, auf eine erste 

10 Speicherstelle in der Hash-Tabelle zuzugreifen, wobei das Verfahren gekennzeichnet ist durch: 

Erschaffen einer Auflosungstabelle (510), die eine Vielzahl von Eintragen enthalt; 

Einfugen eines Eintrages einer Kollision in die erste Speicherstelle in der Hash-Tabelle (504) und in jede Hash- 
's Tabellen-Speicherstelle, bei der eine Hash-Kollision vorkommt, einzufugen, wobei der Eintrag einer Kollision 
(424, 506) eine Bitausblendzahl (M) enthalt, die eine Ausblendfunktion identifiziert, urn einen zweiten Teil (509) 
des ersten Hash-Wertes (408, 500) und einen Zeiger (NTI) auf die Auflosungstabelle (510) auszuwahlen; 

Erzeugen eines Index, der auf den Eintrag einer Kollision (506) und auf den zweiten Teil (509) des ersten 
20 Hash-Wertes (408, 500), der durch die Ausblendfunktion ausgewahlt ist, ansprechempfindlich ist; und 

Zugreifen auf einen Eintrag einer Aufldsung (512, 514) bei einer Speicherstelle in der ersten Auflosungstabelle 
(510), auf die durch den erzeugten Index gezeigt wird. 

25 14. Verfahren gemaB Anspruch 13, 

bei dem das Erzeugen eines Indexes umfasst: 

Verbinden des Zeigers (NTI) eines Kollision eintrages mit dem zweiten Teil (509) des ersten Hash-Wertes (408, 
500). 

30 

15. Verfahren gemaB Anspruch 13, 
welches ferner umfasst: 



Verwenden des ersten Teils (410, 502) des ersten Hash-Wertes (408, 500), urn auf den ersten Speicherplatz 
35 in der Hash-Tabelle (420, 504) zuzugreifen, wobei der erste Teil (41 0, 503) des ersten Hash-Wertes (408, 500) 

von dem zweiten Teil (509) des ersten Hash-Wertes (408, 500) verschieden ist. 

16. Verfahren gemaB Anspruch 13, 
welches femer umfasst, 

Einfugen einen Flag-Satz entweder eines ersten logischen Wertes, wenn der Eintrag ein Eintrag einer Kol- 
lision (424, 506) ist, und eines zweiten logischen Wertes, wenn der Eintrag ein Eintrag einer Nicht-Kollision (426) 
ist, in jede der Vielzahl von Speicherstellen der Hash-Tabelle (420, 504), die einen von null unterschiedlichen 
Eintrag enthalt. 

Verfahren gemaB Anspruch 13, 

bei dem der Eintrag einer Aufldsung ein Eintrag einer Nicht-Kollision (51 2) ist, das Verfahren umfasst femer, 

Einfugen eines Weiterieitungsindex (INDEX) auf eine Ausgabetabelie (438), die eine Ausgabezahl (436) 
enthilt, In den Eintrag einer Aufldsung. 

Verfahren gem§B Anspruch 13, 

bei dem der Eintrag einer Aufldsung ein Eintrag einer Kollision (514) ist, das Verfahren umfasst femer, 

Einfugen einer Bitausblendzahl (M), die eine Ausblendfunktion und einen Zeiger (NTI) auf eine weitere Auf- 
losungstabelle (518) mit einer Vielzahl von Speicherstellen identifiziert, in den Eintrag einer Aufldsung. 

55 19. Verfahren gemaB Anspruch 13, 
welch sf rner umfasst: 



45 17. 



50 18. 



Hach n iher Vielzahl von Eingab zahlen, urn einen Hash-Wert (408, 500) fur jed Eingabezahl zu erzeugen; 

13 
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und 

Verwenden eines jeden Hash-Wertes (408, 500), urn auf eine Speicherstelle in der Hash-Tabelle (420, 504) 
zuzugreifen. 

5 20. Verfahren gemaB Anspruch 13, 
welches ferner umfasst, 

Einfugen eines Weiterleitungseintragsindex (FOR IDX) auf eine Ausgabetabell (438), die eine erste Aus- 
gabezahl (436) in jede der Vielzahi von Speicherzellen der Hash-Tabelle (420, 504), die einen von null verschie- 
denen Eintrag einer Koilision enthalten, enthait. 

10 

21. Verfahren gemaB Anspruch 20, 
welches ferner umfasst: 

Klasifizieren der ersten Eingabezahl als eine von vier Typen; 
*5 Erzeugen einer Hash-Ruckstandstabelle (432) mit einer Vielzahi von Eintragen, wobei ein erster Eintrag einen 

Hash-Wert (430) und einen Typ (428) der ersten Eingabezahl enthait; und 

Verifizieren eines Weiterleitungsindex (FOR IDX) eines Eintrags der Hash-Tabelle, auf den von dem ersten 
Hash-Wert (408, 500) durch Benutzung des ersten Eintrags der Hash-Ruckstandstabelle (432), auf die durch 
den Weiterleitungsindex (FOR IDX) gezeigt wird, zugegriffen wird. 

20 

22. Verfahren gemaB Anspruch 13, 

bei dem die Ausblendfunktion eine Anzahl von Bitpositionen spezifiziert, urn den ersten Hash-Wert (408, 500), 
nachdem der zweite Teil (509) des ersten Hash-Wertes (408, 500) ausgewahlt worden ist, zu verschieben. 

25 23. Verfahren gemaB Anspruch 13, 

bei dem die Ausblendfunktion spezifiziert, wie der Eintrag einer Koilision (424, 506) mit dem zweiten Teil (509) 
des ersten Hash-Wertes (408, 500) zu verbinden ist, urn den ersten Index zu erzeugen. 

24. Verfahren gemaB Anspruch 13, 

30 bei dem die Ausblendfunktion Bits spezifiziert, die von dem ersten Hash-Wert (408, 500) ausgewahlt werdensollen. 

25. Obersetzungsvorrichtung zum Ubersetzen einer Vielzahi von Eingabezahlen in eine Vielzahi von Ausgabezahlen, 
bei der die Vorrichtung umfasst: 

einen Hasher (404), der auf jede der Vielzahi von Eingabezahlen ansprechempfindlich ist, urn ein Hash-Ar- 
gument (408, 500) entsprechend jeder Eingabezahl zu erzeugen, wobei das Hash-Argument (408, 500) eine 
Vielzahi von Bits aufweist; 

eine Hash-Tabelle (420, 504), die eine Vielzahi von Eintr&gen enthait, wobei jeder Eintrag der Vielzahi von 
Eintragen entweder einen Index (FOR IDX) auf eine Ausgabetabelle (438), die eine erste Ausgabezahl (436) 
enthait, Oder eine Bitausblendzahl (M), die eine Ausblendfunktion und einen Zeiger (NTI) auf einer zweiten 
Auflosungstabelle (518) identifiziert, enthait; 

eine erste Auflosungstabelle (51 0), die eine Vielzahi von Eintragen aufweist, wobei jeder Eintrag der Vielzahi 
von Eintragen entweder einen Index (INDEX) in die Ausgabetabelle (438), der eine zweite Ausgabezahl ent- 
hait, oder eine Bitausblendzahl (M), die eine Ausblendfunktion und einen Zeiger (NTI) auf eine zweite Auflo- 
sungstabelle (518) identifiziert, enthait; 

einen ersten Indexgenerator, der, urn auf die Hash-Tabelle (420, 504) zuzugreifen, ansprechempfindlich ist 
auf eine erste Teilmenge (410, 502) der Vielzahi von Bits des Hash-Arguments (408, 500); und 

einen zweiten Indexgenerator (508), um auf die erste Auflosungstabelle (510) zuzugreifen, die ansprechemp- 
findlich auf einen Eintrag (506) in der Hash-Tabelle (420, 504), die eine Bitausblendzahl (M) und einen Zeiger 
(NTI) enthait, ist, und die auf eine zweite Teilmenge (509) der Vielzahi von Bits des Hash-Arguments (408, 
500) ansprechempfindlich ist, wobei kein Bit von dem Hash-Arugument (408, 500) sowohl in die erste Teil- 
meng (41 0, 502) und in die zweite Teilmeng (509) eingeschlossen wird. 

14 
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26. Vorrichtung g maB Anspruch 25, 
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wobei die Vonichtung jede Vielzahl von Eingabezahlen als eine von vier Typen klassifiziert. 

27. Vorrichtung gemaB Anspruch 25, 

wobei jede Speicherstell d r Vielzahl von Speicherstelien in jeder Hash-Tabelle (420, 504) und ersten Aufld- 
5 sungstabell (51 0) einen Kollisions-Flag einschlieBt, wobei f Or jeden Eintrag der Vielzahl von Eintragen, bei denen 

eine Hash-Kollision nicht auftritt, das Flag inen ersten logischen Wert aufweist, und bei dem fur jeden Eintrag 
der Vielzahl von Eintragen, bei denen eine Hash-Kollision auftritt, das Flag einen zweiten logischen Wert aufweist. 



io Revendications 

1. Appareil destine a resoudre une collision de hachage se produisant dans une table de hachage (420) ayant une 
pluralite ^emplacements, la collision de hachagese produisant lorsqu'un premier nombre d'entree genere une 
premiere valeur hach6e (408, 500) et lorsqu'un second nombre d'entree genere une seconde valeur hachee (408, 

is 500), dans lequel une premiere partie (410, 502) de la premiere valeur hachee (408, 500) et une premiere partie 

(41 0, 502) de la seconde valeur hachee (408, 500) ont la meme valeur, la premiere partie (408, 502) de la premiere 
valeur hachee (408, 500) etant utilisee pour acceder a un premier emplacement dans la table de hachage, I'appareil 
etant caracterise par : 

20 une premiere table de resolution (510) contenant une pluralite d'emplacements ; 

un circuit pour inserer une entree de collision (424, 506) au premier emplacement de la table de hachage 
(420, 504) et a chaque emplacement de la table de hachage ou il se produit une collision de hachage, I'entree 
de collision contenant un nombre de masquage de bits (M) identifiant une fonction de masquage pour selec- 
tionner une seconde partie (509) de la premiere valeur hachee (408, 500) et un pointeur (NTI) sur la premiere 

25 table de resolution (508) ; et 

un generateur d'index (508) pour generer un premier index en reponse a I'entree de collision (424, 506) et a 
la seconde partie (509) de la premiere valeur hachee (408, 500) selectionne par la fonction de masquage, 
pour acceder a une entree de resolution (512, 514) a un emplacement de la premiere table de resolution (510), 
le premier index genere polntant sur cet emplacement. 

30 

2. Appareil selon la revendication 1 , dans lequel le generateur d'index (508) combine le pointeur (NTI) contenu dans 
I'entree de collision (424, 506) avec la seconde partie (509) de la premiere valeur hachee (408, 500) pour acceder 
a I'entree de resolution (512, 514). 

35 3. Appareil selon la revendication 1 , dans lequel la premiere partie (410, 502) de la premiere valeur hachee (408, 
500) est utilisee pour acceder au premier emplacement de la table de hachage (420, 504), et dans lequel la 
seconde partie (509) de la premiere valeur hachee (408, 500) utilisee par le generateur d'index (508) est differente 
de la premiere partie (41 0, 502) de la premiere valeur hachee (408, 500). 

to 4. Appareil selon la revendication 1 , dans lequel chacun de la pluralite d'emplacements de la table de hachage (420, 
504) contenant une entree non nulle, contient un indicateur positionne a Tune d'une premiere valeur logique lorsque 
I'entree est une entree de collision (424, 506) et d'une seconde valeur logique lorsque I'entree est une entree de 
non collision (426). 

45 5. Appareil selon la revendication 1 , dans lequel I'entree de resolution est une entree de non collision (426) comportant 
un index de redirection (INDEX) vers une table de sortie (438) qui contient un premier nombre de sortie (436). 

6. Appareil selon la revendication 1 , dans lequel I'entree de resolution (514) est une entree de collision comportant 
un nombre de masquage de bits (M) identifiant une fonction de masquage et un pointeur (NTI) sur une seconde 

so table de resolution (51 8) ayant une pluralite d'emplacements. 

7. Appareil selon la revendication 1 , comprenant en outre un hacheur (404) destine a recevoir une pluralite de nom- 
bres d'entree et ayant pour fonction de generer une valeur hachee (408, 500) pour chaque nombre d'entree de la 
pluralite de nombres d'entree, chaque valeur hachee (408, 500) etant utilisee pour acceder a un emplacement de 

55 la table de hachage (420, 504). 

8. Appareil selon la rev ndication 1, dans lequel chacun d la pluralite d'emplacements de la tab! d hachag (420, 
504) qui contiennent une ritree de non collision non nulle comport un index de redirection vers une table d 

* ■ / r \ ft 
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sortie (438) qui contient un premier nombre de sortie (436). 

9. Appareil selon la revendication 8, dans lequel I'appareil ciasse !e premier nombre d'entree comme etant Tun de 
quatre types, I'appareil comprenant en outr une table de restes de hachage (432) comportant une plurality d'en- 
5 trees, une premiere entree contenant une valeur hach6e (430) et un type (428) du premier nombre d'entree, I'ap- 

pareil ayant pour fonction de verifier un index de redirection (FOR IDX) d'un entree d la table de hachage k 
laquelle accede la premiere valeur hachee (408, 500) en utilisant la premise entree de la table de restes de 
hachage (432), sur laquelle pointe (434) I'index de redirection (FOR IDX). 

10 10. Appareil selon la revendication 1 , dans lequel la fonction de masquage sp6cifie des bits devant etre s6lectionn6s 
k partir de la premiere valeur hach6e (408, 500). 

11. Appareil selon la revindication 1, dans lequel la fonction de masquage specif ie un nombre de positions de bits 
dont la premiere valeur hachee (408, 500) dolt etre decal6e aprfes que la seconde partie (509) de la premiere 

15 valeur hachee (408, 500) a ete s6lectionn6e. 

12. Appareil selon la revendication 1 , dans lequel la fonction de masquage sp6clfie la fagon dont on combine I'entree 
de collision (424, 506) avec la seconde partie (509) de la premiere valeur hachee (408, 500) pour g§n6rer le 
premier index. 



13. Procede de resolution d'une collision de hachage se produisant dans une table de hachage (420) ayant une plu- 
rality d'emplacements, la collision de hachage se produisant lorsqu'un premier nombre d'entree gdnfcre une pre- 
miere valeur hachee (408, 500) et lorsqu'un second nombre d'entree genfere une seconde valeur hachee (408, 
500), dans lequel une premiere partie (410, 503) de la premiere valeur hachee (408, 500) et une premiere partie 
25 (41 0, 502) de la seconde valeur hachee (408, 500) ont la meme valeur, la premiere partie (41 0, 502) de la premiere 
valeur hachee (408, 500) etant utilisee pour acceder k un premier emplacement de ia table de hachage, le procede 
etant caracterlse par : 

la creation d'une table de resolution (510) contenant une plurality d'entrees ; 
30 insertion d'une entree de collision au premier emplacement de la table de hachage (504) et k chaque em- 



placement de la table de hachage ou il se produit une collision de hachage, I'entree de collision (424, 506) 
contenant un nombre de masquage de bits (M) Identifiant une fonction de masquage pour seiectionner une 
seconde partie (509) de la premiere valeur hachee (408, 500) et un pointeur (NTI) sur la premiere table de 
resolution (510); 

la generation d'un index en reponse k I'entree de collision (506) et k la seconde partie (509) de la premiere 
valeur hach6e (408, 500) s6lectionn6e par la fonction de masquage ; et 

I'accfcs k une entree de resolution (512, 514) k un emplacement de la table de resolution (510) sur lequel 
pointe I'index gen6r6. 



la combinaison du pointeur d'entree de collision (NTI) avec la seconde partie (509) de la premiere valeur 
hach6e (408, 500). 



('utilisation de la premiere partie (410, 502) de la premiere valeur hachee (408, 500) pour acc6der au premier 
emplacement de la table de hachage (420, 504), la premiere partie (410, 503) de la premiere valeur hach6e 
(408, 500) etant differente de la seconde partie (509) de la premiere valeur hachee (408, 500). 



50 

16. Proc6de selon la revendication 13, comprenant en outre I'insertion dans chacun de la plurality d'emplacements 
de la table de hachage (420, 504) contenant une entree non nulle, un indicateur positionne k I'une d'une premiere 
valeur logique lorsque I'entree est une entree de collision (424, 506) et d'une seconde valeur logique lorsque 
I'entree est une entree de non collision (426). 

55 

17. Precede s Ion la revendication 13, dans lequel Pentre de resolution est une entre de non collision (512), le 
procede comprenant en outr Pinsertion dans Pentre de resolution d'un index de redirection (INDEX) vers une 
table de sortie (438) qui contient un nombre de sortie (436). 



20 



40 14. Procede selon la revendication 13, dans lequel la generation d'un index comprend : 



45 15. Proc6d6 selon la revendication 13, comprenant en outre : 
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18. Precede selon la revendication 13, dans iequel I'entr6e de resolution est une entree de collision (514), I procede 
comprenant en outr Pinsertion dans I'entree d resolution d'un nombre de masquage de bits (M) identifiant une 
fonction de masquage et d'un pointeur (NTI) sur une autre table de resolution (518) ayant une plurality d'empla- 
cements. 

5 

19. Procede selon la r vendication 13, comprenant en outre : 

le hachage d'une plurality de nombres d'entree pour produlre une valeur hachee (408, 500) pour chacun des 
nombres d'entree ; et 

io I'application de chaque valeur hachee (408, 500) pour acc6der a un emplacement de la table de hachage 

(420, 504). 

20. Proc6de selon la revendication 13 comprenant en outre Pinsertion d'un index d'entree de redirection (FOR IDX) 
vers une table de sortie (438) qui contient un premier nombre de sortie (436) dans chacun de la plurality d'empla- 

15 cements de la table de hachage (420, 504) qui contiennent une entr6e de collision non nulle. 

21 . Procede selon la revendication 20, comprenant en outre : 

le classement du premier nombre d'entree comme etant de Tun de quatre types ; 
20 la generation d'une table de restes de hachage (432) comportant une pluraiite d'entrees, une premiere entree 

contenant une valeur hachee (430) et un type (428) du premier nombre d'entree ; et 
la verification d'un index de redirection (FOR IDX) d'une entree de la table de hachage a laquelle accede la 
premiere valeur hachee (408, 500) en utilisant la premiere entree de la table de restes de hachage (432), sur 
laquelle pointe Pindex de redirection (FOR IDX). 

25 

22. Procede selon la revendication 13, dans Iequel la fonction de masquage specif ie un nombre de positions de bits 
dont la premiere valeur hachee (408, 500) doit etre decaiee apres que la seconde partie (509) de la premiere 
valeur hachee (408, 500) a ete selectionnee. 

30 23. Precede selon la revendication 1 3, dans Iequel la fonction de masquage specifie la facon dont on combine I'entree 
de collision (424, 506) avec la seconde partie (509) de la premiere valeur hachee (424, 506) pour g6n6rer I'index. 

24. Procede selon la revendication 13, dans iequel la fonction de masquage specifie ies bits devant §tre seiectionnes 
a partir de la premiere valeur hachee (408, 500). 

35 

25. Appareil de traduction pour traduire une pluraiite de nombres d'entree en une pluraiite de nombres de sortie, 
I'appareil comprenant : 

un hacheur (404), repondant a chacun de la pluraiite de nombres d'entree en generant un argument hache 
4> (408, 500) correspondant a chaque nombre d'entree, i'argument hache (408, 500) ayant une pluraiite de bits ; 

une table de hachage (420, 504) contenant une pluraiite d'entrees, chaque entr6e de la pluraiite d'entr6es 
contenant sort un index (FOR IDX) sur une table de sortie (438) qui contient un premier nombre de sortie 
(436), sort un nombre de masquage de bits (M) identifiant une fonction de masquage et un pointeur (NTI) sur 
une table de resolution (51 8) ; 

45 une premiere table de resolution (51 0) contenant une pluraiite d'entrees, chaque entree de ia pluraiite d'entrees 

contenant soit un index (INDEX) dans la table de sortie (438) qui contient un second nombre de sortie, soit 
un nombre de masquage de bits (M) identifiant une fonction de masquage et un pointeur (NTI) sur une seconde 
table de resolution (518) ; 

un premier generateur d'index repondant a un premier sous-ensemble (410, 502) de la pluraiite de bits de 
50 i'argument hache (408, 500) en accedant a la table de hachage (420, 504) ; et 

un second generateur d'index (508) pour acceder a la premiere table de resolution (510), en reponse a une 
entree (506) de la table de hachage (420, 504) qui contient un nombre de masquage de bits (M) et un pointeur 
(NTI), et repondant a un second sous-ensemble (509) de la pluraiite de bits de I'argument hache (408, 500), 
dans Iequel aucun bit provenant de I'argument hache (408, 500) n'est contenu ni dans le premier sous-en- 
55 semble (41 0, 502), ni dans le second sous-ensemble (509). 

26. Appareil selon la revendication 25, dans Iequel I'appareil class chacun de la pluraiite de nombres d' ntre comme 



etant d Tun d quatr types, I'appareil comprenant en outr un table de restes d hachag (432) ayant une 
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plurality d'entrees, chaque entree contenant une valeur hachee (430) et un type (428) du nombre d'entree, Tap- 
pareil ayant pour fonction de verifier un index d'une entr6e soit de la table de hachage (420, 504), soit de la premiere 
table d resolution (51 0) en utilisant une entree de la table de restes de hachage (432) sur laquelle pointe I'index. 

5 27. Appareil selon la revendication 25, dans lequel chaque emplacement de la plurality d'emplacements de chaque 
tab! d hachage (420, 504) et de la premiere table de resolution (51 0) contient un indicateur de collision, dans 
lequel, pour chaque entree de la plurality d'entrees pour lesquelles il ne se produit pas de collision de hachage, 
I'indicateur a une premiere valeur logique, et pour chaque entr6e de la plurality d'entrees oil il se produit une 
collision de hachage, I'indicateur a une seconde valeur logique. 
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